package com.py.custom.tms.application.atomic.link;

/**
 * description：
 * 在链表类中实现这些功能：
 * 1、get(index)：获取链表中第 index 个节点的值。如果索引无效，则返回-1。
 * 2、addAtHead(val)：在链表的第一个元素之前添加一个值为 val 的节点。插入后，新节点将成为链表的第一个节点。
 * 3、addAtTail(val)：将值为 val 的节点追加到链表的最后一个元素。
 * 4、addAtIndex(index,val)：在链表中的第 index 个节点之前添加值为 val  的节点。如果 index 等于链表的长度，
 * 则该节点将附加到链表的末尾。如果 index 大于链表长度，则不会插入节点。如果index小于0，则在头部插入节点。
 * 5、deleteAtIndex(index)：如果索引 index 有效，则删除链表中的第 index 个节点。
 *
 * @author pengyou
 * @version 1.0.0
 * @date 2022/4/9
 */
public class MyLinkedList {

    public static void main(String[] args) {

    }

    private ListNode head;

    private int size;

    public int get(int index) {
        if (index < 0 || index >= size) {
            return -1;
        }
        int i = 0;
        ListNode cur = head;
        for (int j = 0; j <= index; j++) {
            cur = cur.next;
        }
        return cur.value;
    }

    public void addAtHead(int val) {
        head = new ListNode(val, head);
    }



    static class ListNode {

        public ListNode() {
        }

        public ListNode(int value) {
            this.value = value;
        }

        public ListNode(int value, ListNode next) {
            this.value = value;
            this.next = next;
        }

        private int value;
        private ListNode next;
    }
}
